# Concurrent Signal Assignment Statements (CSAs)

- Digital systems operate with concurrent signals
- Signals are assigned values at a specific point in time. https://powcoder.com
- ► VHDL uses signaleassignmentistatements
  - ► Specify value and time
- Multiple signal assignment statements are executed concurrently
  - ► Concurrent Signal Assignment Statements (CSAs)



### CSA Statements

- concurrent behavior
  - ► Name of architecture that defines the half\_adder entitessignment Project Exam Help
- signal assignments
  - sum <= (x xor y) after 5 ns;
    </p>
  - ► carry <= (x and y) after 5 hs, powcoder
- Signal assignment operator <=</p>
  - ▶ Describes how output signals depend on input signals
- ► An output signal changes if an input signal has



# after Keyword

- Signal propagation of the XOR and AND gates must be taken into account.
  - ▶ Both garesi genment Regional Example Ip
- signal assignment statements define this through the after Keyword.
- This keyword specifies when the output signal is set to the result of an evaluation after an input signal transition (event).
- ► The textual order of the assignment statement has no influence on the timing.

# library and use clauses

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL;

Assignment Project Exam Help entity 2BA4 is

https://powcoder.com

- A library contains design entities that be used
- ▶ The library IEEE clause defines the IEEE library.
- The library may contain packages.
- ► The above example specifies through the use clause the IEEE.STD\_LOGIC\_1164.ALL packages.
- This package is required for std\_logic type declaration.

#### Full-Adder VHDL library IEEE; use IEEE.STD LOGIC 1164.ALL; Assingulared in 1, in 2, c\_in:in-std\_ulogic; Assingulared in 1, in 2, c\_in:in-std\_ulogic; sum, c\_out:out std\_ulogic ); end fluttapder,/powcoder.com architecture dataflow of full adder is signal \$1,52,53. Std\_ulbgic, POWCO constant gate delay: Time := 5 ns; begin s1 <= (ln1 xor ln2) after gate\_delay; s2 <= (c\_in and s1) after gate\_delay; s3 <= (ln1 and ln2) after gate\_delay; sum <= (s1 xor c\_in) after gate\_delay;</pre> c\_out <= (s2 or s3) after gate\_delay;</pre> end dataflow; CSU22022, 3rd HDL Lecture, Dr. M. Manzke, Page: 7



## Architecture Declaration

```
library IEEE;
  use IEEE.STD LOGIC 1164.ALL;
AssignmentsProject Exam Help
Port (in1, in2, c_in:in std_ulogic;
  end full_adder, powcoder.com
  architected details which the poder coder signal s1,s2,s3: std_ulogic;
  constant gate_delay: Time := 5ns;
  begin
  s1 <= (ln1 xor ln2) after gate_delay;
  s2 <= (c_in and s1) after gate_delay;
  s3 <= (ln1 and ln2) after gate_delay;
  sum <= (s1 xor c_in) after gate_delay;</pre>
  c_out <= (s2 or s3) after gate_delay;
  end dataflow;
```

#### Architecture Body library IEEE; use IEEE.STD LOGIC 1164.ALL; AssignmentsProject Exam Help Port (in1, in2, c\_in:in std\_ulogic; end full\_adder, powcoder.com architected detailed highlips deriveder signal s1,s2,s3: std\_ulogic; constant gate\_delay: Time := 5ns; begin s1 <= (ln1 xor ln2) after gate\_delay; s2 <= (c\_in and s1) after gate\_delay; s3 <= (ln1 and ln2) after gate\_delay; sum <= (s1 xor c\_in) after gate\_delay;</pre> c\_out <= (s2 or s3) after gate\_delay; end dataflow;

#### The Full-Adder Model

- The full-adder simulates the signal transitions at gate-level
- ► The model has three internal signals
- These signal signal project Examy Help
- The internal signals are declared in the architectural declaration
- The Boolean equations define how each signal is derived as function of:
  - Other signals
  - Propagation delay
- ► Constant can be used to declare a constant of a particular type.
- In this case Time

### Signals

- Signals are not variables
  - ▶ History of values over time
  - Waveform Assignment Project Exam Help

signal s1; std\_ulogic := `0`; https://powcoder.com

- Signals may use the assignment symbol: followed by an expression
- ▶ The value of the expression will be initial value of the signal
- ▶ If no initialisation is provided the signal receives a default value
- ► VHDL signal types:
  - ▶ Integer, real, bit\_vector...

# Signals and Time

► A concurrent signal assignment statement (CSA)

sum <= (x xor y) after 5 ns;
Assignment Project Exam Help

- ► In a more general form:

  https://powcoder.com

  signal <= value expression arter time expression;
- In the example Add WeChat powcoder
   if x or y change its value the sum will be assigned the result of the (x xor y) evaluation after 5ns.
- ▶ The Time-value pair represents the future value of the signal.
  - Also called transaction.

# Multiple Signal Transactions

▶ It is possible to specify the following:

s1 < A(x stg w) refer to percy) Etea th reserve x) after 10 ns;

- After one of the signals changed all three waveform elements will be evaluated and scheduled according to their after specification.
- ► The simulation keeps an ordered list of all transactions scheduled for a particular signal.
- ▶ The scheduled transactions are also known as:
  - Projected output waveform.





- In a physical system a wire (signal) has a driver.
- This driver determents the waveform.
   Assignment Project Exam Help
   Up the now every signal had one driver only
- But real systems have shared signals:
  - Buses Add WeChat powcoder
  - ► Wired logic
- ▶ VHDL determines the value of the signal with multiple drivers through a resolution function.

# Resolved Type Declaration

- A shared signal must be declared as a resoled type.
- The previous examples used unresolved types: Assignment Project Exam Help

```
std_ulogic_vector (7 downto 0) std_ulogic_vector (7 downto 0)
```

#### Add WeChat powcoder

► The following declaration will make these signal types resolved:

```
std_logic_vector (7 downto 0);
```